﻿//==================================================================
// Copyright (C) 2011 iSun Studio 软件工作室
// 文件名: DatPhraseDetail.cs
// 作 者：代码自动生成
// 日 期：2011-11-1 10:50:38
// 描 述：
// 版 本：1.00
// 修改历史纪录
// 版 本  修改时间      修改人            修改内容
// 1.00             
//==================================================================
using System;
using System.ComponentModel;
using Csla;
using lite;
using Csla.Validation;
using Csla.Data;
using System.Data.SqlClient;
using OpenExpressApp.ORM;

namespace iSun.Entity
{
	/// <summary>
    /// 
    /// </summary>
	[Serializable]
    [Table(Name="DatPhraseDetail")]
    [iSun.Model.Table("DatPhraseDetail","PhraseID")]
	public class DatPhraseDetail: iSun.Entity.EntityBase
	{
        
        #region Business Methods 业务方法
       
		/// <summary>
        /// 字典编号
        /// </summary>
        private static PropertyInfo< Guid > PhraseIDProperty = RegisterProperty(typeof(DatPhraseDetail),new PropertyInfo< Guid >("PhraseID"));
        [DataObjectField(true, true)]
        [Column, PK]
        public Guid PhraseID
        {
            get { return GetProperty(PhraseIDProperty); }
            set { SetProperty(PhraseIDProperty, value); }
        }
        
		/// <summary>
        /// 字典说明
        /// </summary>
        private static PropertyInfo< string > PhraseTextProperty = RegisterProperty(typeof(DatPhraseDetail),new PropertyInfo< string >("PhraseText"));
        [Column]
        public string PhraseText
        {
            get { return GetProperty(PhraseTextProperty); }
            set { SetProperty(PhraseTextProperty, value); }
        }
		/// <summary>
        /// 字典值
        /// </summary>
        private static PropertyInfo< string > PhraseValueProperty = RegisterProperty(typeof(DatPhraseDetail),new PropertyInfo< string >("PhraseValue"));
        [Column]
        public string PhraseValue
        {
            get { return GetProperty(PhraseValueProperty); }
            set { SetProperty(PhraseValueProperty, value); }
        }
		/// <summary>
        /// 字典类型编号
        /// </summary>
        private static PropertyInfo< Guid > ClassIDProperty = RegisterProperty(typeof(DatPhraseDetail),new PropertyInfo< Guid >("ClassID"));
        [Column]
        public Guid ClassID
        {
            get { return GetProperty(ClassIDProperty); }
            set { SetProperty(ClassIDProperty, value); }
        }
		/// <summary>
        /// 是否停用
        /// </summary>
        private static PropertyInfo< bool > IsPauseProperty = RegisterProperty(typeof(DatPhraseDetail),new PropertyInfo< bool >("IsPause"));
        [Column]
        public bool IsPause
        {
            get { return GetProperty(IsPauseProperty); }
            set { SetProperty(IsPauseProperty, value); }
        }
		/// <summary>
        /// 是否锁定
        /// </summary>
        private static PropertyInfo< bool > IsLockProperty = RegisterProperty(typeof(DatPhraseDetail),new PropertyInfo< bool >("IsLock"));
        [Column]
        public bool IsLock
        {
            get { return GetProperty(IsLockProperty); }
            set { SetProperty(IsLockProperty, value); }
        }
		/// <summary>
        /// 排顺
        /// </summary>
        private static PropertyInfo< int > SeqProperty = RegisterProperty(typeof(DatPhraseDetail),new PropertyInfo< int >("Seq"));
        [Column]
        public int Seq
        {
            get { return GetProperty(SeqProperty); }
            set { SetProperty(SeqProperty, value); }
        }
		/// <summary>
        /// 是否默认值
        /// </summary>
        private static PropertyInfo< bool > IsDefaultProperty = RegisterProperty(typeof(DatPhraseDetail),new PropertyInfo< bool >("IsDefault"));
        [Column]
        public bool IsDefault
        {
            get { return GetProperty(IsDefaultProperty); }
            set { SetProperty(IsDefaultProperty, value); }
        }
		
        #endregion
        
        #region Validation Rules 验证规则
        //将验证规则与业务对象的属性联系在一起
        protected override void AddBusinessRules()
        {
            //AddRule的第一个参数是委托变量，也就是说是方法的变量
            ValidationRules.AddRule(CommonRules.StringRequired, "PhraseText");
            ValidationRules.AddRule(CommonRules.StringMaxLength, new Csla.Validation.CommonRules.MaxLengthRuleArgs("PhraseText", 100));
            ValidationRules.AddRule(CommonRules.StringRequired, "PhraseValue");
            ValidationRules.AddRule(CommonRules.StringMaxLength, new Csla.Validation.CommonRules.MaxLengthRuleArgs("PhraseValue", 50));
            //base.AddBusinessRules();
        }
        #endregion
        
        #region Factory Methods 工厂方法

        public DatPhraseDetail(){}

        public static DatPhraseDetail New()
        {
            return DataPortal.Create< DatPhraseDetail>();
        }
        public static DatPhraseDetail Get(Guid PhraseID)
        {
            return DataPortal.Fetch< DatPhraseDetail>(new SingleLazyCriteria< DatPhraseDetail, Guid>(PhraseID, false));
        }
        public static void Delete(Guid PhraseID)
        {
            DataPortal.Delete(PhraseID);
        }

        //public override DatPhraseDetail Save()
        //{
            //return base.Save();
        //}
        #endregion
		
		#region Data Access 数据访问
        //由于DataPortal_create中没有对数据库的访问，所有标记了Runlocal特性，使得该方法只需在本地运行即可
        //如果代码中有访问数据库的方法，那么就不要用这个特性，使数据门户可以根据情况将此方法的运行选择在应用服务器还是本地
        [RunLocal()]
        protected override void DataPortal_Create()
        {
            //在此调用CheckRules对所有的属性进行验证规则的检查，这样检查只运行一次。
            ValidationRules.CheckRules();
        }


        //可以看到此方法没有标记任何特性
        //此方法要访问数据库所以不能标记本地，由于她没有任何数据库更新操作所以也无需事务性的保护
        //此方法调用结束后会隐含的调用MarkOld（）方法
        private void DataPortal_Fetch(Guid PhraseID)
        {
            //通过连接字符串建立SQL连接对象，Using符号代表，范围释放的意思，SqlConnection对象会在此范围后被释放掉
             using (var ctx = ConnectionManager<SqlConnection>.GetManager(ConnectionStringNames))
            {
                IDb db = DbFactory.Instance.GetDb(ctx.Connection);
                IQuery q = db.Query();
                q.Constrain("PhraseID").Equal(PhraseID);
                var data = db.Select< DatPhraseDetail>(q)[0];
                LoadProperty(PhraseIDProperty, data.PhraseID);
                LoadProperty(PhraseTextProperty, data.PhraseText);
                LoadProperty(PhraseValueProperty, data.PhraseValue);
                LoadProperty(ClassIDProperty, data.ClassID);
                LoadProperty(IsPauseProperty, data.IsPause);
                LoadProperty(IsLockProperty, data.IsLock);
                LoadProperty(SeqProperty, data.Seq);
                LoadProperty(IsDefaultProperty, data.IsDefault);
            }
        }

        [Transactional(TransactionalTypes.TransactionScope)]
        protected override void DataPortal_DeleteSelf()
        {
            //依然是调用下面的方法删除的，只是他此时可以获得自己的Id
            DataPortal_Delete(PhraseIDProperty);
        }
        #endregion

	}
}

